<template>
  <div>
    <!-- Header 头部区域 -->
    <div class="search-header">
      <!-- 后退图标 -->
      <van-icon
        name="arrow-left"
        color="white"
        size="18"
        class="goback"
        @click="$router.back()"
      />
      <!-- 搜索组件 -->
      <van-search
        v-model.trim="kw"
        placeholder="请输入搜索关键词"
        shape="round"
        ref="searchRef"
        @input="onInput"
      />
    </div>
    <!-- 搜索建议 -->
    <div class="sugg-list" v-if="kw.length != 0">
      <div
        class="sugg-item"
        v-for="(item, i) in suggestList"
        :key="i"
        v-html="item"
        @click="gotoSearchResult"
      ></div>
    </div>
    <!-- 搜索历史 -->
    <div class="search-history" v-else>
      <!-- 标题 -->
      <van-cell title="搜索历史">
        <!-- 使用 right-icon 插槽来自定义右侧图标 -->
        <template #right-icon>
          <van-icon name="delete" class="search-icon" />
        </template>
      </van-cell>

      <!-- 历史列表 -->
      <div class="history-list">
        <span
          class="history-item"
          v-for="(tag, i) in history"
          :key="i"
          @click="gotoSearchResult"
          >{{ tag }}</span
        >
      </div>
    </div>
  </div>
</template>

<script>
import { getSuggestListAPI } from '@/api/searchAPI.js'

export default {
  name: 'Search',
  data () {
    return {
      // 搜索关键词
      kw: '',
      timerId: '',
      // 搜素建议列表
      suggestList: [],
      // 搜索历史
      history: JSON.parse(localStorage.getItem('history') || '[]')
    }
  },
  mounted () {
    // 如果搜索组件的 ref 引用存在，则获取下面的 input 输入框，使其自动获得焦点
    this.$refs.searchRef && this.$refs.searchRef.querySelector('input').focus()
  },
  methods: {
    onInput () {
      // 2. 清除上次的延时器
      clearTimeout(this.timerId)
      // 3. 判断输入框是否有值,没有的话不开定时器
      if (this.kw.length === 0) {
        // 清空搜索建议的列表数据
        this.suggestList = []

        return
      }
      // 1. 开启延时器，将延时器的 id 存储到 this.timerId 中
      this.timerId = setTimeout(() => {
        // 简化代码,调用搜索建议
        this.initSuggestList()
      }, 500)
    },
    // 初始化搜素建议列表
    async initSuggestList () {
      const { data: res } = await getSuggestListAPI(this.kw)
      console.log(res)
      if (res.message === 'OK') {
        // 1. 调用 hlightKeywords 方法，对关键词进行高亮处理
        this.hlightKeywords(res.data.options)
        // 2. 将高亮的结果，赋值给 suggestList
        this.suggestList = res.data.options

        // 把关键词加入搜索历史中
        const newHistory = this.history.filter(item => item !== this.kw)
        newHistory.unshift(this.kw)
        this.history = newHistory
      }
    },
    // 高亮搜索关键词的方法，形参中的 arr 是搜索建议的数组
    hlightKeywords (arr) {
      // 1. 根据用户输入的 kw，动态创建正则表达式
      const reg = new RegExp(this.kw, 'ig')

      // 循环数组中的每一项
      arr.forEach((item, index) => {
        // 2. TODO：调用字符串的 replace 方法，进行关键词的高亮处理
        arr[index] = item.replace(reg, val => {
          return `<span style="color: red; font-weight: bold;">${val}</span>`
        })
      })
    },
    gotoSearchResult (e) {
      // e.currentTarget 是当正在触发事件的那个元素
      // console.log(e.currentTarget.innerText)

      // 1. 获取用户当前点击的搜索建议项的内容
      const text = e.currentTarget.innerText

      // 2. 通过编程式导航 API，跳转到搜索结果页
      this.$router.push('/search/' + text)
    }
  },
  watch: {
    // 监视历史记录的变化
    history (newVal) {
      // 持久化存储到本地
      localStorage.setItem('history', JSON.stringify(newVal))
    }
  }
}
</script>

<style lang="less" scoped>
.search-header {
  height: 46px;
  display: flex;
  align-items: center;
  background-color: #e54d42;
  overflow: hidden;
  // 后退按钮
  .goback {
    padding-left: 14px;
  }
  // 搜索组件
  .van-search {
    flex: 1;
  }
}
.sugg-list {
  .sugg-item {
    padding: 0 15px;
    border-bottom: 1px solid #f8f8f8;
    font-size: 14px;
    line-height: 50px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
  }
}
.search-icon {
  font-size: 16px;
  line-height: inherit;
}

.history-list {
  padding: 0 10px;
  .history-item {
    display: inline-block;
    font-size: 12px;
    padding: 8px 14px;
    background-color: #efefef;
    margin: 10px 8px 0px 8px;
    border-radius: 10px;
  }
}
</style>
